import { createApp } from 'vue'

import Cookies from 'js-cookie'

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
import locale from 'element-plus/es/locale/lang/zh-cn'

import '@/assets/styles/index.scss' // global css

import App from './App'
import store from './store'
import router from './router'
import directive from './directive' // directive

import globalComponent from "@/utils/globalComponent";//全局组件
import utils from "@/utils/utils";//全局方法
import apis from "@/api/index.js";//全局API
import config from "@/config/index.js";//全局API

// 注册指令
import plugins from './plugins' // plugins

// svg图标
import 'virtual:svg-icons-register'
import SvgIcon from '@/components/SvgIcon'
import elementIcons from '@/components/SvgIcon/svgicon'

import './permission' // permission control


const app = createApp(App)

// 全局组件挂载
for (const componentItme in globalComponent) {
  app.component(componentItme, globalComponent[componentItme])
}

//全局方法挂载
app.config.globalProperties.$utils = utils
//全局API
app.config.globalProperties.$apis = apis
//全局配置
app.config.globalProperties.$config = config

app.use(router)
app.use(store)
app.use(plugins)
app.use(elementIcons)
app.component('svg-icon', SvgIcon)

directive(app)

// 使用element-plus 并且设置全局的大小
app.use(ElementPlus, {
  locale: locale,
  // 支持 large、default、small
  size: Cookies.get('size') || 'default'
})

app.mount('#app')
